On Improving Transactional Memory: Optimistic Transactional Boosting, Remote Execution, and Hybrid Transactions
نویسندگان
چکیده
(ABSTRACT) Transactional memory (TM) has emerged as a promising synchronization abstraction for multi-core architectures. Unlike traditional lock based approaches, TM shifts the burden of synchronization from the programmer to an underlying framework using hardware (HTM) and/or software (STM) components. Although STM provides a generic solution for developing more complex concurrent applications , it suffers from scalability challenges due to the intensive speculation and meta-data handling. Moreover, In specific components such as transactional data structures, this intensive speculation results in more false conflicts than the optimized concurrent data structures. On the other hand, as computer architects and vendors chose the design of simple best-effort HTM components, HTM imposes limitations on the transactions and provides no guarantees for the transactions to eventually commit in hardware. These limitations raise the need to move into two (orthogonal) directions. The first direction is to design efficient hybrid TM frameworks which minimize the overhead of any HTM/STM interconnection. The second direction is to enhance the performance of the fall-back STM paths themselves, including enhancing specific components such as transactional data structures. In this dissertation, we propose two approaches to enhance the overall TM performance. First, we design an optimistic methodology for transactional boosting to specifically enhance the performance of the transactional data structures. Second, we enhance the performance of STM in general by dedicating hardware cores for executing specific parts of the transactions like commit and invalidation. In both approaches, we first show a pure software solution. Then we propose a hybrid TM solution which exploits the new HTM features of the currently released Intel's Haswell processor. Optimistic transactional boosting (OTB) is a methodology to design a transactional versions of the highly concurrent lazy data structures. An earlier (pessimistic) boosting proposal adds a layer of abstract locks on top of the optimized concurrent data structures. We propose an optimistic methodology of boosting which allows greater data structure-specific optimizations, easier integration with STM frameworks, and lower restrictions on the boosted operations than the original pessimistic boosting methodology. Based on our proposed OTB methodology, we implement transactional versions of both set and priority queue. We also extend the design of DEUCE, a Java STM framework, to support OTB integration. Using our extension, programmers can include both OTB data structure operations and traditional memory reads/writes in the same transaction. Results show that OTB performance is closer to the optimal lazy (non-transactional) data structures than the original boosting algorithm. Remote …
منابع مشابه
HiperTM: High Performance, Fault-Tolerant Transactional Memory
We present HiperTM, a high performance active replication protocol for fault-tolerant distributed transactional memory. The active replication paradigm allows transactions to execute locally, costing them only a single network communication step during transaction execution. Shared objects are replicated across all sites, avoiding remote object accesses. Replica consistency is ensured by a) OS-...
متن کاملSpeculative Execution on Distributed and Replicated Software Transactional Memory Systems
This paper describes and evaluates SPECULA, a distributed and replicated software transactional memory system based on a certification scheme. This system tackles the negative effects of network latency, through the optimistic execution of code. Transactions are executed on a single node, in an uncoordinated fashion, and the result of their local validation is used as a prediction of the result...
متن کاملAggressive Transactional Boosting
Traditional software transactional memory systems implemented synchronization and recovery by tracking pertransaction memory access. In recent work, we introduced transactional boosting, a methodology whereby performance is improved by forgoing read/write sets and relying on data structure commutativity and abstract locks for synchronization. In this paper, we advocate a new aggressive form of ...
متن کاملCoarse-grained transactions (extended version)
Traditional transactional memory systems suffer from overly conservative conflict detection, yielding so-called false conflicts, because they are based on fine-grained, low-level read/write conflicts. In response, the recent trend has been toward integrating various abstract data-type libraries using adhoc methods of high-level conflict detection. These proposals have led to improved performanc...
متن کاملCoarse - Grained Transactions [ Extended
Traditional transactional memory systems suffer from overly conservative conflict detection, yielding so-called false conflicts, because they are based on fine-grained, low-level read/write conflicts. In response, the recent trend has been toward integrating various abstract data-type libraries using ad-hoc methods of high-level conflict detection. These proposals have led to improved performan...
متن کامل